草庐IT

c++ getline和stringstream

全部标签

c++ - 为什么 getline 跳过第一行?

在下面的代码中,getline()跳过读取第一行。我注意到在注释“cin>>T”行时,它正常工作。但我想不通原因。我想在读取行之前读取一个整数!如何解决?#includeusingnamespacestd;intmain(){intT,i=1;stringline;cin>>T;while(i 最佳答案 cin>>T;这会消耗您在标准输入中提供的整数。第一次调用:getline(cin,line)...您使用整数后的换行符。可以得到cin至ignore通过在cin>>T;之后添加以下行来换行:std::cin.ignore(std:

c++ - 如何使用 write with stringstream?

我有一个vector我要写入的数据std::stringstream.我试过:my_ss.write(vector.data(),vector.size());...但它似乎没有将任何内容放入my_ss我声明如下:std::stringstreammy_ss(std::stringstream::binary);为什么write不工作(应用程序没有崩溃并且编译时出现0个错误,0个警告)? 最佳答案 对于“我该怎么做”,您可以使用std::ostream_iterator:std::copy(vector.begin(),vector

c++ - 为什么从管道读取时 libc++ getline 会阻塞,而 libstdc++ getline 不会?

长话短说使用libc++版本的getline函数的程序在从管道读取输入时会阻塞,直到管道的缓冲区已满。NOTlibstdc++版本的getline函数也是如此:这里函数立即读取并返回一行输入作为一旦可用。我是否应该预料到libstdc++和libc++之间存在这种行为差异?[编辑:我不是在这里征求意见,我只是对管道了解不够,也不知道实现C++标准库的困难。对我来说,这种行为上的差异肯定是令人惊讶的,但也许有人更了解并且可以向我保证这种差异是可以预料的,也许这只是一个实现细节?]更重要的是,我可以做些什么来使libc++表现得像libstdc++那样?也就是说,getline函数不应该等

c++ - 启用 _GLIBCXX_DEBUG 后,Stringstream 无法使用 double

我正在使用_GLIBCXX_DEBUG模式来帮助查找我的代码中的错误,但我遇到了一个问题,我认为这是库中的一个错误,但希望有人能告诉我我只是做错了什么。这是一个重现问题的简短示例:#define_GLIBCXX_DEBUG#include#includeintmain(intargc,constchar*argv[]){std::ostringstreamostr;ostr如果我注释掉#define,那么输出是(如预期的那样):Result:1.2有了_GLIBCXX_DEBUG定义,但是输出很简单:Result:我已经追踪到流的_M_num_put字段被保留为NULL,这导致在流中抛

c++ getline 似乎无法识别通过管道传输到标准输入的输入中的换行符

这段代码:$猫垃圾.cpp#include#include#include#includeusingnamespacestd;intmain(intargc,char**argv){stringline;while(getline(cin,line)){cout如果我运行它就可以正常工作,然后输入“hi”和“there”$垃圾你好你好那里那里到目前为止一切顺利。但是我有另一个程序:$猫junk1.c#includeintmain(intargc,char**argv){inti=4;while(i--){printf("abc\n");sleep(1);}return0;}这个输出4行

c++ - 带有 stringstreams 的 strdup 导致 valgrind 错误

我有以下问题:我正在编写一个必须环绕C库的C++程序,所以当我与库交互时,我总是必须使用char*而不是std::string用于所有操作。为了尽可能避免使用char*,我使用stringstreams进行格式化,例如:#include#include#include#includeusingnamespacestd;intmain(intargc,char**argv){ostringstreamstr;str就输出而言,程序正确输出“./test+hello”。但是,valgrind给了我很多类型的错误==30350==Invalidreadofsize1==30350==at0x

c++ - 类似 istream::getline() 的东西,但有替代的 delim 字符?

获得istream::getline(string,256,'\n'OR';')效果的最简洁方法是什么?我知道编写循环非常简单,但我觉得我可能遗漏了一些东西。我是吗?我用过的:while((is.peek()!='\n')&&(is.peek()!=';'))stringstream.put(is.get()); 最佳答案 不幸的是,没有办法有多个“行尾”。您可以做的是阅读该行,例如std::getline并将其放入std::istringstream并使用std::getline(使用';'分隔符)在istringstream的循

c++ - 为什么 stringstream 会产生奇怪的值?

因此,我正在尝试在我的程序中使用字符串流,以便获得一些格式化的字符串(尤其是因为我需要将数字转换为字符串)。问题是,我的程序崩溃了,当我用VisualStudio调试它时,在我的Spy窗口中,我看到我的stringstream的字符串缓冲区产生了(当试图向它添加“Framerate”时):"FramerateÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍýνý««««««««ÍÍÍþ"代码:std::stringstreams;s当我尝试获取关联的字符串时,我的代码将崩溃...我找不到任何解释,也找不到我的代码的问题......编辑:事实证明这些字符不是问题,stringstream使用

c++ 使用单行 m.swap(std::stringstream()); 清除字符串流?

我一直在使用下面的代码来清除std::stringstream:m.swap(std::stringstream());代码可能取自thisSOthread.最近我在VisualStudio2013中编译我的代码并收到以下警告:warningC4239:nonstandardextensionused:'argument':conversionfrom'std::basic_stringstream,std::allocator>'to'std::basic_stringstream,std::allocator>&'1>Anon-constreferencemayonlybeboun

c++ - stringstream 内部是如何工作的?

我问的是性能方面的问题。stringstream只是一个字符串/vector,所以写入它可能会导致其整个内容被复制到更大的内存块,还是以更棘手的方式(例如,字符串列表或其他)完成? 最佳答案 27.7.3/1表示basic_ostringstream使用basic_stringbuf。我认为27.7.1.3/8说basic_stringbuf通过重新分配缓冲区来腾出空间,甚至不能保证指数增长(因此分摊O(1)追加)。但我发现标准的流部分非常难以理解,并且始终存在“假设”规则。所以我不能向你保证,在下面使用deque(并在有人请求字符